<ui:composition xmlns="http://www.w3.org/1999/xhtml"
                xmlns:ui="http://java.sun.com/jsf/facelets"
                xmlns:h="http://java.sun.com/jsf/html"
                xmlns:f="http://java.sun.com/jsf/core"
                xmlns:p="http://primefaces.org/ui"
                template="../templates/principal.xhtml">

    <ui:define name="content" id="content">
        <h:form id="frmCategoria">
            <p:panel id="panel" header="Bem Vindo ao Cadastro de Categoria">
                <p:growl id="messages" life="5000" />

                <p:dataTable id="tabCategoria" widgetVar="wtabCategoria" var="categoria" value="#{categoriaBean.lazyModel}" 
                             lazy="true" paginator="true" rows="12" paginatorPosition="top"
                             emptyMessage="Nenhum Registro Retornado ..." filterEvent="enter">

                    <p:column headerText="Descrição" sortBy="#{categoria.dscCategoria}" filterBy="#{categoria.dscCategoria}" >
                        <div style="text-align: left; ">
                            <h:outputText value="#{categoria.dscCategoria}" />
                        </div>
                    </p:column>

                    <p:column headerText="Tipo" sortBy="#{categoria.dscTipCategoria}" filterBy="#{categoria.dscTipCategoria}"
                              filterOptions="#{categoriaBean.tipCategoriaOptions}" filterMatchMode="exact">
                        <h:outputText value="#{categoria.dscTipCategoria}" />
                    </p:column>

                    <p:column style="width: 100px;">
                        <h:panelGrid columns="4" styleClass="actions" cellpadding="0">
                            <p:commandButton id="selectButtonCategoria" update=":frmCategoria:panel :frmCategoria:messages" 
                                             icon="ui-icon-search" title="Visualizar // Alterar Categoria" oncomplete="PF('categoriaDialog').show()">
                                <f:setPropertyActionListener value="#{categoria}" target="#{categoriaBean.selectedCategoria}" />
                            </p:commandButton>

                            <p:commandButton id="excluirButtonCategoria" update=":frmCategoria:panel :frmCategoria:messages" 
                                             icon="ui-icon-trash" title="Excluir Categoria" oncomplete="PF('confirmation').show()">
                                <f:setPropertyActionListener value="#{categoria}" target="#{categoriaBean.selectedCategoria}" />
                            </p:commandButton>
                        </h:panelGrid>
                    </p:column>

                    <f:facet name="footer">
                        <div style="text-align: left;">
                            <p:commandButton id="incluirButtonCategoria" actionListener="#{categoriaBean.preparaInserir}" 
                                             update=":frmCategoria:panel :frmCategoria:messages" value="Nova Categoria"
                                             icon="ui-icon-pencil" title="Cadastrar Nova Categoria" oncomplete="PF('categoriaDialog').show()" />
                        </div>
                    </f:facet>
                </p:dataTable>

                <p:dialog id="dialog" header="Detalhes Categoria" widgetVar="categoriaDialog" resizable="true"
                          width="600" showEffect="explode" hideEffect="explode" style="text-align: left">
                    <p:panelGrid id="display" columns="2" style="margin-bottom:50px; text-align: left">

                        <h:outputText value="Descrição:" />
                        <p:inputText id="Descricao" value="#{categoriaBean.selectedCategoria.dscCategoria}" style="width:400px; font-weight:bold;" />

                        <h:outputText value="Tipo:" />
                        <p:selectOneMenu id="slTipCategoria" value="#{categoriaBean.selectedCategoria.tipCategoria}" style="width:250px; font-weight:bold;">
                            <f:selectItems value="#{categoriaBean.categorias}" />
                        </p:selectOneMenu>

                    </p:panelGrid>

                    <p:commandButton value="Inserir" update=":frmCategoria:panel :frmCategoria:messages"
                                     actionListener="#{categoriaBean.inserir}" oncomplete="PF('categoriaDialog').hide()" />
                    <p:commandButton value="Alterar" update=":frmCategoria:panel :frmCategoria:messages"
                                     actionListener="#{categoriaBean.alterar}" oncomplete="PF('categoriaDialog').hide()" />
                </p:dialog>

                <p:dialog header="Confirma a Exclusão dessa Categoria: #{categoriaBean.selectedCategoria.dscCategoria}?" widgetVar="confirmation">

                    <p:commandButton value="Sim" update=":frmCategoria:panel :frmCategoria:messages" oncomplete="PF('confirmation').hide(), PF('categoriaDialog').hide()"
                                     actionListener="#{categoriaBean.excluir}" />
                    <p:commandButton value="Não" onclick="PF('confirmation').hide()" type="button" />

                </p:dialog>
            </p:panel>
        </h:form>
    </ui:define>
</ui:composition>